<template>
  <div>
    <nav-header/>
    <nav-bread>
      <span slot="two">地址选择</span>
    </nav-bread>
    <div class="checkout-page">
      <svg style="position: absolute; width: 0; height: 0; overflow: hidden;" version="1.1"
           xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
        <defs>
          <symbol id="icon-add" viewBox="0 0 31 32">
            <title>add</title>
            <path class="path1"
                  d="M30.745 15.152h-14.382v-14.596c0-0.308-0.243-0.557-0.543-0.557s-0.543 0.249-0.543 0.557v14.596h-14.665c-0.3 0-0.543 0.249-0.543 0.557s0.243 0.557 0.543 0.557h14.665v15.177c0 0.307 0.243 0.557 0.543 0.557s0.543-0.249 0.543-0.557v-15.177h14.382c0.3 0 0.543-0.249 0.543-0.557s-0.243-0.557-0.543-0.557z"></path>
          </symbol>
          <symbol id="icon-ok" viewBox="0 0 32 32">
            <title>ok</title>
            <path class="path1"
                  d="M14.084 20.656l-7.845-9.282c-1.288-1.482-3.534-1.639-5.016-0.351s-1.639 3.534-0.351 5.016l10.697 12.306c1.451 1.669 4.057 1.623 5.448-0.096l18.168-22.456c1.235-1.527 0.999-3.765-0.528-5.001s-3.765-0.999-5.001 0.528l-15.573 19.337z"></path>
          </symbol>
          <symbol id="icon-edit" viewBox="0 0 32 32">
            <title>edit</title>
            <path class="path1"
                  d="M28.287 8.51l-4.805-4.806 0.831-0.831c0.472-0.472 1.086-0.777 1.564-0.777 0.248 0 0.452 0.082 0.622 0.253l3.143 3.144c0.539 0.54 0.133 1.529-0.524 2.186l-0.831 0.831zM26.805 9.992l-1.138 1.138-4.805-4.806 1.138-1.138 4.805 4.806zM24.186 12.612l-14.758 14.762-4.805-4.806 14.758-14.762 4.805 4.806zM7.379 28.288l-4.892 1.224 1.223-4.894 3.669 3.67zM31.123 4.011l-3.143-3.144c-0.567-0.567-1.294-0.867-2.103-0.867-1.036 0-2.174 0.52-3.045 1.391l-20.429 20.436c-0.135 0.134-0.23 0.302-0.276 0.487l-2.095 8.385c-0.089 0.355 0.017 0.736 0.276 0.995 0.198 0.198 0.461 0.307 0.741 0.307 0.085 0 0.171-0.010 0.254-0.031l8.381-2.096c0.185-0.047 0.354-0.142 0.487-0.276l20.43-20.436c1.409-1.41 2.042-3.632 0.524-5.15v0z"></path>
          </symbol>
          <symbol id="icon-del" viewBox="0 0 32 32">
            <title>delete</title>
            <path class="path1"
                  d="M11.355 4.129v-2.065h9.29v2.065h-9.29zM6.194 29.935v-23.742h19.613v23.742h-19.613zM30.968 4.129h-8.258v-3.097c0-0.569-0.463-1.032-1.032-1.032h-11.355c-0.569 0-1.032 0.463-1.032 1.032v3.097h-8.258c-0.569 0-1.032 0.463-1.032 1.032s0.463 1.032 1.032 1.032h3.097v24.774c0 0.569 0.463 1.032 1.032 1.032h21.677c0.569 0 1.032-0.463 1.032-1.032v-24.774h3.097c0.569 0 1.032-0.463 1.032-1.032s-0.463-1.032-1.032-1.032v0z"></path>
            <path class="path2"
                  d="M10.323 9.806c-0.569 0-1.032 0.463-1.032 1.032v14.452c0 0.569 0.463 1.032 1.032 1.032s1.032-0.463 1.032-1.032v-14.452c0-0.569-0.463-1.032-1.032-1.032z"></path>
            <path class="path3"
                  d="M16 9.806c-0.569 0-1.032 0.463-1.032 1.032v14.452c0 0.569 0.463 1.032 1.032 1.032s1.032-0.463 1.032-1.032v-14.452c0-0.569-0.463-1.032-1.032-1.032z"></path>
            <path class="path4"
                  d="M21.677 9.806c-0.569 0-1.032 0.463-1.032 1.032v14.452c0 0.569 0.463 1.032 1.032 1.032s1.032-0.463 1.032-1.032v-14.452c0-0.569-0.463-1.032-1.032-1.032z"></path>
          </symbol>
          <symbol id="icon-clock" viewBox="0 0 32 32">
            <title>clock</title>
            <path class="path1"
                  d="M29.333 16c0-7.364-5.97-13.333-13.333-13.333s-13.333 5.97-13.333 13.333c0 7.364 5.97 13.333 13.333 13.333s13.333-5.97 13.333-13.333v0 0 0 0 0 0zM0 16c0-8.837 7.163-16 16-16s16 7.163 16 16c0 8.837-7.163 16-16 16s-16-7.163-16-16zM14.667 14.667v1.333h2.667v-10.667h-2.667v9.333zM24 18.667h1.333v-2.667h-10.667v2.667h9.333z"></path>
          </symbol>
          <symbol id="icon-question" viewBox="0 0 32 32">
            <title>question</title>
            <path class="path1"
                  d="M16 2.56c7.411 0 13.44 6.029 13.44 13.44s-6.029 13.44-13.44 13.44c-7.411 0-13.44-6.029-13.44-13.44s6.029-13.44 13.44-13.44zM16 0c-8.822 0-16 7.178-16 16s7.178 16 16 16c8.822 0 16-7.178 16-16s-7.178-16-16-16z"></path>
            <path class="path2"
                  d="M16 22.080c-1.059 0-1.92 0.861-1.92 1.92s0.861 1.92 1.92 1.92c1.059 0 1.92-0.861 1.92-1.92s-0.861-1.92-1.92-1.92z"></path>
            <path class="path3"
                  d="M12.16 12.48c0.706 0 1.28-0.574 1.28-1.28 0-1.412 1.148-2.56 2.56-2.56s2.56 1.148 2.56 2.56c0 1.412-1.148 2.56-2.56 2.56-0.706 0-1.28 0.574-1.28 1.28v3.84c0 0.706 0.574 1.28 1.28 1.28s1.28-0.574 1.28-1.28v-2.723c2.224-0.575 3.84-2.616 3.84-4.957 0-2.823-2.297-5.12-5.12-5.12s-5.12 2.297-5.12 5.12c0 0.706 0.574 1.28 1.28 1.28z"></path>
          </symbol>
        </defs>
      </svg>
      <div class="container">
        <div class="checkout-addr">
          <div class="page-title-normal">
            <h2 class="page-title-h2"><span>check out</span></h2>
          </div>
          <!-- process step -->
          <div class="check-step">
            <ul>
              <li class="cur"><span>选择</span> 地址</li>
              <li><span>订单</span> 详情</li>
              <li><span>确认</span> 支付</li>
              <li><span>支付</span> 信息</li>
            </ul>
          </div>

          <!-- address list -->
          <div class="page-title-normal checkout-title">
            <h2><span>收货地址</span></h2>
          </div>
          <div class="addr-list-wrap">
            <div class="addr-list">
              <ul>
                <li v-for="(item,index) in addressListFilter" :class="{'check':checkIndex===index}"
                    @click="selectid(item,index)">
                  <dl>
                    <dt>{{item.userName}}</dt>
                    <dd class="address">{{item.streetName}}</dd>
                    <dd class="tel">{{item.tel}}</dd>
                  </dl>
                  <div class="addr-opration addr-del" @click="deladderConfirm(item.streetName,item._id)">
                    <a href="javascript:;" class="addr-del-btn">
                      <svg class="icon icon-del">
                        <use xlink:href="#icon-del"></use>
                      </svg>
                    </a>
                  </div>
                  <div class="addr-opration addr-set-default" v-if="!item.isDefault">
                    <a href="javascript:;" class="addr-set-default-btn" @click="setDefaultadder(item._id)"><i>设置为默认</i></a>
                  </div>
                  <div class="addr-opration addr-default" v-if="item.isDefault">默认地址</div>
                </li>
                <li class="addr-new" @click="addaddressmodal=true">
                  <div class="add-new-inner">
                    <i class="icon-add">
                      <svg class="icon icon-add">
                        <use xlink:href="#icon-add"></use>
                      </svg>
                    </i>
                    <p>添加收货地址</p>
                  </div>
                </li>
              </ul>
            </div>

            <div class="shipping-addr-more">
              <a class="addr-more-btn up-down-btn" href="javascript:;" @click="moreshow" :class="{'open':limit>3}">
                more
                <i class="i-up-down">
                  <i class="i-up-down-l"></i>
                  <i class="i-up-down-r"></i>
                </i>
              </a>
            </div>
          </div>

          <!-- shipping method-->
          <div class="page-title-normal checkout-title">
            <h2><span>配送方式</span></h2>
          </div>
          <div class="lemall-msg-info hidden">
            <span>The region you selected is not within our delivery area. Please select another shipping address within our delivery areas.</span>
          </div>
          <div class="shipping-method-wrap">
            <div class="shipping-method">
              <ul>
                <li class="check">
                  <div class="name">顺丰快递</div>
                  <div class="price">免费</div>
                  <div class="shipping-tips">
                    <p>一旦发货，订单应在1-7个工作日内抵达目的地</p>
                  </div>
                </li>
              </ul>
            </div>
          </div>
          <div class="next-btn-wrap">
            <a @click="next" class="btn btn--m btn--red"
               :class="{'btn--dis':!nexts}">下一步
            </a>
          </div>
        </div>
      </div>
    </div>
    <nav-footer/>
    <Modal v-bind:mdShow="delmodal" @close="closeModal">
      <p slot="message">你确定要删除 <span style="color: red">{{deladdername}}</span> 吗?</p>
      <div slot="btngroup">
        <a href="javascript:;" class="btn btn--m" @click="deladder">确认</a>
        <a href="javascript:;" class="btn btn--m" @click="closeModal">取消</a>
      </div>
    </Modal>
    <Modal v-bind:mdShow="noadderid" @close="closeModal">
      <p slot="message">必须选择一个收货地址哦!</p>
      <div slot="btngroup">
        <a href="javascript:;" class="btn btn--m" @click="closeModal">关闭</a>
      </div>
    </Modal>
    <!--添加收货地址-->
    <Modal v-bind:mdShow="addaddressmodal" @close="closeModal">
      <div slot="message">
        <div class="error-wrap">
          <div slot="mdtitle" style="font-size: 20px;font-weight: 600">添加收货地址</div>
          <span class="error error-show">{{errmsg}}</span>
        </div>
        <ul>
          <li class="regi_form_input">
            <i class="iconfont icon-xingming"></i>
            <input type="text" tabindex="1" name="loginname" placeholder="请输入收货姓名" class="regi_login_input"
                   v-model="addername">
          </li>
          <li class="regi_form_input noMargin">
            <i class="iconfont icon-phone"></i>
            <input type="text" tabindex="1" name="password" placeholder="请输入收货电话" class="regi_login_input"
                   v-model="phone">
          </li>
          <li class="regi_form_input noMargin">
            <i class="iconfont icon-gongsiyoubian"></i>
            <input type="text" tabindex="1" name="password" placeholder="请输入邮编编码(选填)" class="regi_login_input"
                   v-model="code"/>
          </li>
          <li class="regi_form_input noMargin">
            <i class="iconfont icon-address_icon"></i>
            <input type="text" tabindex="1" name="password" placeholder="请输入收货地址" class="regi_login_input"
                   v-model="address">
          </li>
        </ul>
      </div>
      <div slot="btngroup">
        <a href="javascript:;" class="btn btn--m" @click="closeModal">关闭</a>
        <a href="javascript:;" class="btn btn--m" @click="addressfun">添加</a>
      </div>
    </Modal>

  </div>
</template>

<script>

  import '@/assets/css/checkout.css'
  import NavHeader from './../components/Headers'
  import NavFooter from './../components/Footer'
  import NavBread from './../components/Bread'
  import Modal from './../components/modal'
  import axios from 'axios'

  export default {
    data() {
      return {
        limit: 3,
        nexts: false,
        checkIndex: false,
        addressList: [],
        delmodal: false,
        deladderid: '',
        deladdername: '',
        selectedadderid: '',
        noadderid: false,
        addaddressmodal: false,
        errmsg: '',
        addername: '',
        phone: '',
        address: '',
        code: ''
      }
    },
    mounted() {
      this.getaddress();
    },
    methods: {
      getaddress() {
        axios.get('/goods/addresslist').then(res => {
          if (res.status === 200 && res.data.code === 0) {
            this.addressList = res.data.result.addressList
          }
        });
      },
      moreshow() {
        if (this.limit < this.addressList.length) {
          this.limit = this.addressList.length
        } else {
          this.limit = 3;
        }
      },
      setDefaultadder(addressid) {
        axios.post('/goods/setdefaultadder', {addressid}).then(res => {
          if (res.status === 200 && res.data.code === 0) {
            this.getaddress();
          } else {
            alert("设置失败");
          }
        });
      },
      deladderConfirm(name, id) {
        this.deladdername = name;
        this.deladderid = id;
        this.delmodal = true;
      },
      closeModal() {
        this.delmodal = false;
        this.noadderid = false;
        this.addaddressmodal = false;
      },
      deladder() {
        axios.post('/goods/deladdress', {addressId: this.deladderid}).then(res => {
          if (res.status === 200 && res.data.code === 0) {
            this.delmodal = false,
              this.deladderid = '',
              this.deladdername = ''
            this.getaddress();
          } else {
            alert(res.data.msg);
          }
        });
      },
      selectid(item, index) {
        this.checkIndex = index;
        this.selectedadderid = item._id;
        this.nexts = true;
      },
      next() {
        if (this.selectedadderid == '') {
          this.noadderid = true
          return false;
        }
        this.$router.push({path: 'order', query: {addressid: this.selectedadderid}});
      },
      addressfun() {
        if (this.addername == '') {
          this.errmsg = "收货姓名不能为空";
          return false
        }
        if (this.phone == '') {
          this.errmsg = "收货电话不能为空";
          return false
        }
        if (this.address == '') {
          this.errmsg = "收货地址不能为空";
          return false
        }
        axios.post('/users/addaddress', {
          addername: this.addername,
          phone: this.phone,
          address: this.address,
          code: this.code
        }).then(res => {
          if (res.status === 200 && res.data.code === 0) {
            this.addername = '';
            this.phone = '';
            this.address = '';
            this.code = '';
            this.getaddress();
            this.closeModal();
          }
        });
      }
    },
    components: {
      NavHeader,
      NavFooter,
      NavBread,
      Modal
    },
    computed: {
      addressListFilter() {
        return this.addressList.slice(0, this.limit)
      }
    }
  }
</script>

<style scoped>
  .iconfont {
    font-size: 24px;
    display: inline-block;
    float: left;
    width: 25px;
    height: 29px;
    margin: 0 0 0 10px;
  }

  @media only screen and (max-width: 767px) {
    .regi_form_input .regi_login_input {
      top: -29px !important;
    }
  }
</style>
